<template>
  <div class="login">
    <BaseHeader mode="light" backMode="dark" backImg="close">
      <template v-slot:right>
        <span class="f14" @click="$nav('/login/help')">帮助与设置</span>
      </template>
    </BaseHeader>
    <Loading v-if="loading.getPhone"/>
    <div v-else class="content">
      <div class="desc">
        <div class="title">登录看朋友内容</div>
        <div class="phone-number">138****8000</div>
        <div class="sub-title">认证服务由中国移动提供</div>
      </div>

      <dy-button type="primary" :loading="loading.login" :active="false" :loadingWithText="true" @click="login">
        {{ loading.login ? '登录中' : '一键登录' }}
      </dy-button>
      <dy-button :active="false" type="white" @click="$nav('/login/other')">其他手机号码登录</dy-button>

      <div class="protocol" :class="showAnim?'anim-bounce':''">
        <Tooltip style="top: -100%;left: -10rem;" v-model="showTooltip"/>
        <div class="left">
          <Check v-model="isAgree"/>
        </div>
        <div class="right">
          我已阅读并同意
          <span class="link" @click="$nav('/service-protocol',{type:'“抖音”用户服务协议'})">用户协议</span>
          和
          <span class="link" @click="$nav('/service-protocol',{type:'“抖音”隐私政策'})">隐私政策</span>
          <div>
            以及
            <span class="link" @click="$nav('/service-protocol',{type:'中国移动认证服务协议'})">《中国移动认证服务条款》</span>
            ，同时登录并使用抖音火山版（原“火山小视频”）和抖音
          </div>
        </div>
      </div>

      <div class="other-login">
        <transition name="fade">
          <div v-if="isOtherLogin" class="icons">
            <img @click="$no" src="../../assets/img/icon/login/toutiao-round.png" alt="">
            <img @click="$no" src="../../assets/img/icon/login/qq-round.webp" alt="">
            <img @click="$no" src="../../assets/img/icon/login/wechat-round.png" alt="">
            <img @click="$no" src="../../assets/img/icon/login/weibo-round.webp" alt="">
          </div>
        </transition>
      </div>
      <transition name="fade">
        <span v-if="!isOtherLogin" class="other-login-text link" @click="isOtherLogin = !isOtherLogin">其他方式登录</span>
      </transition>
    </div>
  </div>
</template>
<script>
import Check from "../../components/Check";
import Tooltip from "./components/Tooltip";
import Loading from "../../components/Loading";

export default {
  name: "login",
  components: {
    Check,
    Tooltip,
    Loading
  },
  data() {
    return {
      isAgree: false,
      isOtherLogin: false,
      showAnim: false,
      showTooltip: false,
      loading: {
        login: false,
        getPhone: false,
      }
    }
  },
  computed: {
  },
  created() {
    this.getPhone()
  },
  methods: {
    async getPhone() {
      this.loading.getPhone = true
      await this.$sleep(1000)
      this.loading.getPhone = false
    },
    login() {
      if (this.isAgree) {
        this.loading.login = true
      } else {
        if (!this.showAnim && !this.showTooltip) {
          this.showAnim = true
          setTimeout(() => {
            this.showAnim = false
            this.showTooltip = true
          }, 500)
          setTimeout(() => {
            this.showTooltip = false
          }, 3000)
        }
      }
    }
  }
}
</script>

<style scoped lang="less">
@import "../../assets/less/index";

.login {
  position: fixed;
  left: 0;
  right: 0;
  bottom: 0;
  top: 0;
  overflow: auto;
  color: black;
  font-size: 14rem;
  background: white;

  .content {
    padding: 60rem 30rem;

    .desc {
      margin-bottom: 60rem;
      margin-top: 120rem;
      display: flex;
      align-items: center;
      flex-direction: column;

      .title {
        margin-bottom: 20rem;
      }

      .phone-number {
        letter-spacing: 3rem;
        font-size: 30rem;
        margin-bottom: 10rem;
      }

      .sub-title {
        font-size: 12rem;
        color: @second-text-color;
      }
    }

    .button {
      width: 100%;
      margin-bottom: 5rem;
    }

    .protocol {
      position: relative;
      color: gray;
      margin-top: 20rem;
      font-size: 12rem;
      display: flex;

      .left {
        padding-top: 1rem;
        margin-right: 5rem;
      }
    }


    .other-login {
      position: absolute;
      bottom: 40rem;
      font-size: 12rem;
      display: flex;
      justify-content: center;
      width: calc(100vw - 60rem);
      transform: translateX(-50%);
      left: 50%;

      .icons {
        img {
          width: 40rem;
          margin-right: 15rem;

          &:nth-last-child(1) {
            margin-right: 0;
          }
        }
      }
    }

    .other-login-text {
      position: absolute;
      bottom: 55rem;
      font-size: 12rem;
      transform: translateX(-50%);
      left: 50%;
    }
  }
}
</style>
